<template>
  <basic-container>
    <avue-crud
      :option="option"
      :table-loading="loading"
      :data="data"
      :page.sync="page"
      :permission="permissionList"
      :before-open="beforeOpen"
      v-model="form"
      ref="crud"
      @row-update="rowUpdate"
      @row-save="rowSave"
      @row-del="rowDel"
      @search-change="searchChange"
      @search-reset="searchReset"
      @selection-change="selectionChange"
      @current-change="currentChange"
      @size-change="sizeChange"
      @refresh-change="refreshChange"
    >
      <template slot="header">
        <div class="content cell">
          <div class="titles">
            {{ name }}统计表（{{ startMonth }}-{{ endMonth }}）
          </div>
          <div class="info">
            <div class="item">
              <div class="leftItem">所属组织：{{ deptName }}</div>
              <div class="rightItem">
                会计期间：{{ startMonth }}-{{ endMonth }}
              </div>
            </div>
            <div class="item">
              <div class="leftItem">姓名：{{ name }}</div>
              <div class="rightItem">套该等级：{{ levelName }}</div>
            </div>
            <div class="item">
              <div class="leftItem">银行卡号：{{ bankNo }}</div>
              <div class="rightItem">职务：{{ postName }}</div>
            </div>
          </div>
        </div>
      </template>
      <template slot="searchMenu">
        <el-button
          size="small"
          plain
          icon="el-icon-download"
          @click="handleExport"
          >数据导出
        </el-button>
      </template>
      <!-- <template slot="page"
        ><div class="page">
          <div class="label">总合计：</div>
          <div class="props">{{ total }}</div>
        </div></template
      > -->
    </avue-crud>
  </basic-container>
</template>

<script>
import { getPersonList } from "@/api/statistics/level";
import $Excel from "avue-plugin-excel";
export default {
  data() {
    return {
      levelName: "",
      deptName: "",
      name: "",
      bankNo: "",
      startMonth: "",
      endMonth: "",
      postName: "",
      total: 0,
      form: {},
      query: {
        startMonth: this.getRecentMonth_Date(12)[0],
        endMonth: this.getRecentMonth_Date(12)[1],
      },
      loading: true,
      page: {
        pageSize: 10,
        currentPage: 1,
        total: 0,
      },
      selectionList: [],
      data: [],
    };
  },
  computed: {
    ids() {
      let ids = [];
      this.selectionList.forEach((ele) => {
        ids.push(ele.id);
      });
      return ids.join(",");
    },
    option() {
      return {
        tip: false,
        menu: false,
        searchShow: true,
        searchMenuSpan: 6,
        border: true,
        index: false,
        viewBtn: false,
        emptyBtn: false,
        addBtn: false,
        header: false,
        selection: false,
        // align: "center",
        dialogClickModal: false,
        // header: false,
        searchBtnText: "查询",
        emptyBtnText: "重置",
        sumText: "合计",
        showSummary: true,
        sumColumnList: [
          {
            label: "合计：",
            name: "postWages",
            type: "sum",
          },
          {
            label: " ",
            name: "levelWages",
            type: "sum",
          },
          {
            label: " ",
            name: "workAllowance",
            type: "sum",
          },
          {
            label: " ",
            name: "remoteAreas",
            type: "sum",
          },
          {
            label: " ",
            name: "rescueAllowance",
            type: "sum",
          },
          {
            label: " ",
            name: "basicWages",
            type: "sum",
          },
          {
            label: " ",
            name: "dutyAllowance",
            type: "sum",
          },
          {
            label: " ",
            name: "sceneAllowance",
            type: "sum",
          },
          {
            label: " ",
            name: "otherAllowance",
            type: "sum",
          },
          {
            label: " ",
            name: "allowanceTotal",
            type: "sum",
          },
          {
            label: " ",
            name: "dayWages",
            type: "sum",
          },
          {
            label: " ",
            name: "workNum",
            type: "sum",
          },
          {
            label: " ",
            name: "reissue",
            type: "sum",
          },
          {
            label: " ",
            name: "achievementBonus",
            type: "sum",
          },
          {
            label: " ",
            name: "payableTotal",
            type: "sum",
          },
          {
            label: " ",
            name: "deductingSocial",
            type: "sum",
          },
          {
            label: " ",
            name: "deductingAccumulation",
            type: "sum",
          },
          {
            label: " ",
            name: "deductingSpecial",
            type: "sum",
          },
          {
            label: " ",
            name: "paidIn",
            type: "sum",
          },
          {
            label: " ",
            name: "paidAmount",
            type: "sum",
          },
          {
            label: " ",
            name: "deductingTotal",
            type: "sum",
          },
          {
            label: " ",
            name: "actualTotal",
            type: "sum",
          },
        ],
        align: "center",
        column: [
          {
            label: "日期区间",
            prop: "createTime",
            type: "monthrange",
            format: "yyyy-MM",
            valueFormat: "yyyy-MM",
            searchRange: true,
            searchValue:
              this.query.createTime && this.query.createTime.length > 0
                ? this.query.createTime
                : [`${this.query.startMonth}`, `${this.query.endMonth}`],
            searchClearable: false,
            showColumn: false,
            pickerOptions: {
              disabledDate(time) {
                return time.getTime() > Date.now();
              },
            },
            search: true,
          },
          {
            label: "姓名",
            prop: "name",
            showColumn: false,
            search: true,
            searchValue: this.query.name,
          },
          {
            label: "身份证号",
            prop: "idCard",
            width: 200,
            showColumn: false,
            search: true,
            searchValue: this.query.idCard,
          },
          // {
          //   label: "组织名称",
          //   prop: "couponType",
          //   type: "tree",
          //   dicUrl: "/api/fine-system/dept/lazy-list",
          //   props: {
          //     label: "deptName",
          //     value: "id",
          //   },
          //   filterable: true,
          //   showColumn: false,
          //   search: true,
          //   dicFormatter: (res) => {
          //     return res.data;
          //   },
          // },
          {
            label: "会计期间",
            prop: "accountPeriod",
            align: "center",
          },
          {
            label: "岗位/职务工资",
            prop: "postWages",
            align: "center",
          },
          {
            label: "等级工资",
            prop: "levelWages",
            align: "center",
          },
          {
            label: "工作性津贴",
            prop: "workAllowance",
            align: "center",
          },
          {
            label: "生活性津贴",
            prop: "lifeAllowance",
          },
          {
            label: "艰苦边远津贴",
            prop: "remoteAreas",
            align: "center",
          },
          {
            label: "消防救援津贴(扣除750元绩效奖金)",
            prop: "rescueAllowance",
            align: "center",
          },
          {
            label:
              "基本工资555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555555",
            prop: "basicWages",
            align: "center",
          },
          {
            label: "消防执勤补贴",
            prop: "dutyAllowance",
            align: "center",
          },
          {
            label: "现场救援补贴",
            prop: "sceneAllowance",
            align: "center",
          },
          {
            label: "其他补贴",
            prop: "otherAllowance",
            align: "center",
          },
          {
            label: "补贴合计",
            prop: "allowanceTotal",
            align: "center",
          },
          {
            label: "天工资",
            prop: "dayWages",
            align: "center",
          },
          {
            label: "工作天数",
            prop: "workNum",
            align: "center",
          },
          {
            label: "补发",
            prop: "reissue",
            align: "center",
          },
          {
            label: "补发备注",
            prop: "reissueNote",
            align: "center",
          },
          {
            label: "绩效奖金",
            prop: "achievementBonus",
            align: "center",
          },
          {
            label: "应发合计",
            prop: "payableTotal",
            align: "center",
          },
          {
            label: "扣除社保个人部分",
            prop: "deductingSocial",
            align: "center",
          },
          {
            label: "扣除公积金个人部分",
            prop: "deductingAccumulation",
            align: "center",
          },
          {
            label: "个税专项扣除部分",
            prop: "deductingSpecial",
            align: "center",
          },
          {
            label: "个税实缴金额",
            prop: "paidIn",
            align: "center",
          },
          {
            label: "个税实缴档位",
            prop: "paidLevel",
            align: "center",
          },
          {
            label: "个税实缴比例",
            prop: "paidProp",
            align: "center",
          },
          {
            label: "个税缴纳金额",
            prop: "paidAmount",
            align: "center",
          },
          {
            label: "扣除合计",
            prop: "deductingTotal",
            align: "center",
          },
          {
            label: "实发合计",
            prop: "actualTotal",
            align: "center",
          },
          {
            label: "备注",
            prop: "note",
            align: "center",
          },
        ],
      };
    },
  },
  mounted() {
    this.loading = false;
  },
  methods: {
    getRecentMonth_Date(n) {
      const datenow = new Date();
      const dateend =
        datenow.getFullYear().toString() +
        "-" +
        (datenow.getMonth() + 1).toString();
      datenow.setMonth(datenow.getMonth() - n);
      let dyear = datenow.getFullYear();
      let dmonth = datenow.getMonth() + 1;
      dmonth = dmonth < 10 ? 0 + dmonth : dmonth;
      const datestart = dyear.toString() + "-" + dmonth.toString();
      return [datestart, dateend];
    },
    handleExport() {
      let opt = {
        title: `${this.name}统计表（${this.query.startMonth}-${this.query.endMonth}）`,
        column: [
          {
            label: `${this.name}统计表（${this.query.startMonth}-${this.query.endMonth}）`,
            display: false,
            children: [
              {
                label: `所属组织：${this.deptName}`,
                display: false,
                children: [
                  {
                    label: `姓名：${this.name}`,
                    children: [
                      {
                        label: `银行卡号：${this.bankNo}`,
                        children: [
                          {
                            label: "日期区间",
                            prop: "createTime",
                            type: "monthrange",
                            format: "yyyy-MM",
                            valueFormat: "yyyy-MM",
                            searchRange: true,
                            searchValue:
                              this.query.createTime &&
                              this.query.createTime.length > 0
                                ? this.query.createTime
                                : [
                                    `${this.query.startMonth}`,
                                    `${this.query.endMonth}`,
                                  ],
                            searchClearable: false,
                            showColumn: false,
                            pickerOptions: {
                              disabledDate(time) {
                                return time.getTime() > Date.now();
                              },
                            },
                            search: true,
                          },
                          {
                            label: "姓名",
                            prop: "name",
                            showColumn: false,
                            search: true,
                            searchValue: this.query.name,
                          },
                          {
                            label: "身份证号",
                            prop: "idCard",
                            showColumn: false,
                            width: 200,
                            search: true,
                            searchValue: this.query.idCard,
                          },
                          // {
                          //   label: "组织名称",
                          //   prop: "couponType",
                          //   type: "tree",
                          //   dicUrl: "/api/fine-system/dept/lazy-list",
                          //   props: {
                          //     label: "deptName",
                          //     value: "id",
                          //   },
                          //   filterable: true,
                          //   showColumn: false,
                          //   search: true,
                          //   dicFormatter: (res) => {
                          //     return res.data;
                          //   },
                          // },
                          {
                            label: "会计期间",
                            prop: "accountPeriod",
                            align: "center",
                          },
                          {
                            label: "岗位/职务工资",
                            prop: "postWages",
                            align: "center",
                          },
                          {
                            label: "等级工资",
                            prop: "levelWages",
                            align: "center",
                          },
                          {
                            label: "工作性津贴",
                            prop: "workAllowance",
                            align: "center",
                          },
                          {
                            label: "生活性津贴",
                            prop: "lifeAllowance",
                          },
                          {
                            label: "艰苦边远津贴",
                            prop: "remoteAreas",
                            align: "center",
                          },
                          {
                            label: "消防救援津贴(扣除750元绩效奖金)",
                            prop: "rescueAllowance",
                            align: "center",
                          },
                          {
                            label: "基本工资合计",
                            prop: "basicWages",
                            align: "center",
                          },
                          {
                            label: "消防执勤补贴",
                            prop: "dutyAllowance",
                            align: "center",
                          },
                          {
                            label: "现场救援补贴",
                            prop: "sceneAllowance",
                            align: "center",
                          },
                          {
                            label: "其他补贴",
                            prop: "otherAllowance",
                            align: "center",
                          },
                          {
                            label: "补贴合计",
                            prop: "allowanceTotal",
                            align: "center",
                          },
                          {
                            label: "天工资",
                            prop: "dayWages",
                            align: "center",
                          },
                        ],
                      },
                    ],
                  },
                ],
              },
              {
                label: `会计期间：${this.startMonth}-${this.endMonth}`,
                children: [
                  {
                    label: `套该等级：${this.levelName}`,
                    children: [
                      {
                        label: `职务：${this.postName}`,
                        children: [
                          {
                            label: "工作天数",
                            prop: "workNum",
                            align: "center",
                          },
                          {
                            label: "补发",
                            prop: "reissue",
                            align: "center",
                          },
                          {
                            label: "补发备注",
                            prop: "reissueNote",
                            align: "center",
                          },
                          {
                            label: "绩效奖金",
                            prop: "achievementBonus",
                            align: "center",
                          },
                          {
                            label: "应发合计",
                            prop: "payableTotal",
                            align: "center",
                          },
                          {
                            label: "扣除社保个人部分",
                            prop: "deductingSocial",
                            align: "center",
                          },
                          {
                            label: "扣除公积金个人部分",
                            prop: "deductingAccumulation",
                            align: "center",
                          },
                          {
                            label: "个税专项扣除部分",
                            prop: "deductingSpecial",
                            align: "center",
                          },
                          {
                            label: "个税实缴金额",
                            prop: "paidIn",
                            align: "center",
                          },
                          {
                            label: "个税实缴档位",
                            prop: "paidLevel",
                            align: "center",
                          },
                          {
                            label: "个税实缴比例",
                            prop: "paidProp",
                            align: "center",
                          },
                          {
                            label: "个税缴纳金额",
                            prop: "paidAmount",
                            align: "center",
                          },
                          {
                            label: "扣除合计",
                            prop: "deductingTotal",
                            align: "center",
                          },
                          {
                            label: "实发合计",
                            prop: "actualTotal",
                            align: "center",
                          },
                          {
                            label: "备注",
                            prop: "note",
                            align: "center",
                          },
                        ],
                      },
                    ],
                  },
                ],
              },
            ],
          },
        ],
        data: this.data,
      };
      $Excel.excel({
        title: opt.title,
        columns: opt.column,
        data: opt.data,
      });
    },
    searchReset() {
      this.query = {};
      this.onLoad(this.page);
    },
    searchChange(params, done) {
      if (params.createTime) {
        params.startMonth = params.createTime[0];
        params.endMonth = params.createTime[1];
        delete params.createTime;
      }
      this.query = params;
      this.page.currentPage = 1;
      this.onLoad(this.page, params);
      done();
    },
    refreshChange() {
      this.onLoad(this.page, this.query);
    },
    onLoad(page, params = {}) {
      this.loading = true;
      getPersonList(
        page.currentPage,
        page.pageSize,
        Object.assign(params, this.query)
      )
        .then((res) => {
          const data = res.data.data;
          this.levelName = data.levelName;
          this.deptName = data.deptName;
          this.name = data.name;
          this.bankNo = data.bankNo;
          this.startMonth = data.startMonth;
          this.endMonth = data.endMonth;
          this.postName = data.postName;
          this.data = data.dataList;
          this.loading = false;
        })
        .catch(() => {
          this.data = [];
          this.loading = false;
        });
    },
  },
};
</script>

<style scoped lang="scss">
.page {
  width: 100%;
  height: 30px;
  text-align: left;
  font-size: 16px;
  display: flex;
  align-items: center;
}
/deep/.avue-crud__pagination {
  padding: 0;
}

.content {
  background: #fafafa;
  border-left: 1px solid #ebeef5;
  border-top: 1px solid #ebeef5;
  border-right: 1px solid #ebeef5;
  font-size: 14px;
  color: rgba(0, 0, 0, 0.85);
  word-break: break-word;
  line-height: 23px;
  font-weight: bold;
  .titles {
    text-align: center;
    padding: 10px 0;
    border-bottom: 1px solid #ebeef5;
  }
  .info {
    .item {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 8px 14px;
      .leftItem {
        width: 50%;
      }
      .rightItem {
        width: 20%;
      }
    }
  }
}
</style>
